{% extends 'layout/basic.html' %}
{% load static %}

{% block title %}用户登录{% endblock %}


{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    <style>
        .error-msg {
            color: red;
            position: absolute;
        }
    </style>
{% endblock %}


{% block content %}
    <div class="account">
        <div class="title">用户登录</div>
        <form method="POST" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                <span class="error-msg">{{ field.errors.0 }}</span>
                            </div>
                            <div class="col-xs-5">
{#                                <input id="btnSms" type="button" class="btn btn-default" value="点击获取验证码">#}
                                <img src="{% url 'image_code' %}" alt="验证码" title="看不清？换一张试试！" id="imgCode">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg">{{ field.errors.0 }}</span>
                    </div>
                {% endif %}
            {% endfor %}

            <div>
                <div style="float: right;"><a href="{% url 'login_sms' %}">短信登录？</a></div>
            </div>

            <div class="row">
                <div class="col-xs-3">
                    <input type="submit" class="btn btn-primary" value="登  录"/>
                </div>
            </div>
        </form>
    </div>
{% endblock %}


{% block js %}
    <script>
        $(function () {
            bindClickBtnSms();
            bindClickSubmint();
            bindClickImgCode();
        })

        /*
        * 点击获取验证码的函数
        * */
        function bindClickBtnSms() {
            $('#btnSms').click(function () {
                $('.error-msg').empty();

                // 获取用户输入的手机号
                // 找到输入框的id，根据id获取值。form生成的输入框，id默认形式为id_(字段名)
                var mobilePhone = $('#id_mobile_phone').val();

                // 发送Ajax请求，把手机号发送到后台
                $.ajax({
                    url: '{% url 'send_sms' %}', // 等价于 /send_sms/
                    type: 'GET',
                    data: {mobile_phone: mobilePhone, tpl: 'login',},
                    dataType: 'JSON',
                    success: function (res) {
                        // ajax请求发送成功后会自动执行，res是后端返回的值
                        console.log(res);

                        if (res.status) {
                            console.log('发送成功，倒计时');
                            sendSmsRemind();
                        } else {
                            console.log(res);
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })
        }

        /*
        * 点击提交登录信息*/
        function bindClickSubmint() {
            $('#btnSubmint').click(function () {
                $('.error-msg').empty();
                // 点击提交按钮绑定的事件，采用Ajax提交
                $.ajax({
                    url: '{% url 'login_sms' %}',
                    type: 'POST',
                    data: $('#smsForm').serialize(),
                    // 这个form表单中的所有数据，包括csrf_token
                    dataType: 'JSON',
                    success: function (res) {
                        {#console.log(res);#}
                        if (res.status) {
                            location.href = res.data; // 后端将data中的URL返回，然后前端跳转到这个URL
                        } else {
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0]);
                            })
                        }
                    }
                })
            })
        }

        function sendSmsRemind() {
            var $smsBtn = $('#btnSms');
            $smsBtn.prop('disabled', true);

            var time = 60;
            var remind = setInterval(function () {
                $smsBtn.val(time + '秒后重新获取');
                time -= 1;
                if (time < 1) {
                    clearInterval(remind);
                    $smsBtn.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000)
        }

        function bindClickImgCode() {
            $('#imgCode').click(function () {
                var oldSrc = $(this).attr('src');
                $(this).attr('src', oldSrc+'?');
            })
        }
    </script>
{% endblock %}